Crate secp256k1_sys
source ·Expand description
secp256k1-sys FFI bindings
Direct bindings to the underlying C library functions. These should not be needed for most users.
Modules
- recovery
recovery
FFI of the recovery module
Macros
- Implement methods and traits for types that contain an inner array.
Structs
- A Secp256k1 context, containing various precomputed values and such needed to do elliptic curve computations. If you create one of these with
secp256k1_context_create
you MUST destroy it withsecp256k1_context_destroy
, or else you will have a memory leak. - Library-internal representation of a ElligatorSwift encoded group element.
- Library-internal representation of a Secp256k1 public key
- Data structure that contains additional arguments for schnorrsig_sign_custom.
- Library-internal representation of a Secp256k1 signature
Constants
- Flag for keys to indicate compressed serialization format
- Flag for keys to indicate uncompressed serialization format
- Flag for context to enable no precomputation
- Flag for context to enable signing precomputation
- Flag for context to enable verification precomputation
Statics
- Default ECDH hash function
- Default ECDH hash function for BIP324 key establishment
Traits
- A trait for producing pointers that will always be valid in C (assuming NULL pointer is a valid no-op).
Functions
- Does a best attempt at secure erasure using Rust intrinsics.
- rustsecp256k1_v0_9_2_context_create⚠
alloc
and non-rust_secp_no_symbol_renaming
A reimplementation of the C functionsecp256k1_context_create
in rust. - rustsecp256k1_v0_9_2_context_destroy⚠
alloc
and non-rust_secp_no_symbol_renaming
- rustsecp256k1_v0_9_2_default_error_callback_fn⚠Non-
rust_secp_no_symbol_renaming
This function is an override for the C function, this is the an edited version of the original description: - rustsecp256k1_v0_9_2_default_illegal_callback_fn⚠Non-
rust_secp_no_symbol_renaming
This function is an override for the C function, this is the an edited version of the original description: - secp256k1_context_create⚠
alloc
and non-rust_secp_no_symbol_renaming
A reimplementation of the C functionsecp256k1_context_create
in rust. - secp256k1_context_destroy⚠
alloc
and non-rust_secp_no_symbol_renaming
A reimplementation of the C functionsecp256k1_context_destroy
in rust. - secp256k1_context_preallocated_clone⚠Non-
secp256k1_fuzz
- secp256k1_context_preallocated_clone_size⚠Non-
secp256k1_fuzz
- secp256k1_context_preallocated_create⚠Non-
secp256k1_fuzz
- secp256k1_context_preallocated_size⚠Non-
secp256k1_fuzz
- secp256k1_context_randomize⚠Non-
secp256k1_fuzz
- secp256k1_ec_pubkey_cmp⚠Non-
secp256k1_fuzz
- secp256k1_ec_pubkey_combine⚠Non-
secp256k1_fuzz
- secp256k1_ec_pubkey_create⚠Non-
secp256k1_fuzz
- secp256k1_ec_pubkey_negate⚠Non-
secp256k1_fuzz
- secp256k1_ec_pubkey_parse⚠Non-
secp256k1_fuzz
- secp256k1_ec_pubkey_serialize⚠Non-
secp256k1_fuzz
- secp256k1_ec_pubkey_tweak_add⚠Non-
secp256k1_fuzz
- secp256k1_ec_pubkey_tweak_mul⚠Non-
secp256k1_fuzz
- secp256k1_ecdh⚠Non-
secp256k1_fuzz
- secp256k1_ecdsa_sign⚠Non-
secp256k1_fuzz
- secp256k1_ecdsa_verify⚠Non-
secp256k1_fuzz
- secp256k1_keypair_create⚠Non-
secp256k1_fuzz
- secp256k1_keypair_xonly_pub⚠Non-
secp256k1_fuzz
- secp256k1_keypair_xonly_tweak_add⚠Non-
secp256k1_fuzz
- secp256k1_schnorrsig_sign⚠Non-
secp256k1_fuzz
- secp256k1_schnorrsig_sign_custom⚠Non-
secp256k1_fuzz
- secp256k1_schnorrsig_verify⚠Non-
secp256k1_fuzz
- secp256k1_xonly_pubkey_cmp⚠Non-
secp256k1_fuzz
- secp256k1_xonly_pubkey_from_pubkey⚠Non-
secp256k1_fuzz
- secp256k1_xonly_pubkey_parse⚠Non-
secp256k1_fuzz
- secp256k1_xonly_pubkey_serialize⚠Non-
secp256k1_fuzz
- secp256k1_xonly_pubkey_tweak_add⚠Non-
secp256k1_fuzz
- secp256k1_xonly_pubkey_tweak_add_check⚠Non-
secp256k1_fuzz
Type Aliases
- Hash function to use to post-process an ECDH point to get a shared secret.
- A hash function used by
ellswift_ecdh
to hash the final ECDH shared secret. - A nonce generation function. Ordinary users of the library never need to see this type; only if you need to control nonce generation do you need to use it. I have deliberately made this hard to do: you have to write your own wrapper around the FFI functions to use it. And it’s an unsafe type. Nonces are generated deterministically by RFC6979 by default; there should be no need to ever change this.
- Same as secp256k1_nonce function with the exception of accepting an additional pubkey argument and not requiring an attempt argument. The pubkey argument can protect signature schemes with key-prefixed challenge hash inputs against reusing the nonce when signing with the wrong precomputed pubkey.